# **COMM\_REG IP SPEC**

## **Table of Contents**

| Introduction                  | 2  |
|-------------------------------|----|
| Feature                       | 2  |
| Register Definition           | 2  |
| Register Map                  |    |
| Functional Details            | 8  |
| Block Diagram                 | 8  |
| Module input/output list      | 9  |
| COMM_REG function description | 16 |
|                               |    |

## Introduction

The COMM\_REG module is to receive writing signals and change internal registers, and to generate setting bits for other modules, or to read out data for daisy chain or SPI interface. For fault register bits, excepting for writing from interface, inputs also come from fault inputs.

### **Feature**

Key features of the COMM REG module are:

- •support writing registers
- •support MTP writing and can load data from MTP
- •read-only bits can be read out by communication interface
- fault registers can be set by fault inputs, and cleared by writing via interface

# **Register Definition**

## **Register Map**

|            | Covered by | Covered by |
|------------|------------|------------|
|            | MTP_CRC?   | CONF_CRC?  |
| SPF_CONF   |            | Υ          |
| SF_CONF    |            | Υ          |
| LF_SM_CONF |            | Υ          |
| SPF_FUNC   |            |            |
| SF_FUNC    |            |            |
| LF_SM_FUNC |            |            |
| TM         |            | Υ          |
| TRIM       | Υ          | Υ          |
| FLT_SUM    |            |            |
| FLT_BIT    |            |            |

Table1 block class1

| Name       | Add    | D7         | D6             | D5                   | D4        | D3         | D2         | D1         | D0         | Default    | Block      |
|------------|--------|------------|----------------|----------------------|-----------|------------|------------|------------|------------|------------|------------|
| DEV_ADD1   | 0x0000 | TOP_DEV    |                |                      |           | ADD<6:0>   |            |            | 1          | 80         | SPF_CONF   |
| DEV_ADD2   | 0x0001 |            |                |                      |           | NUM<6:0>   |            |            |            | 00         | SPF_CONF   |
| COMM_CONF1 | 0x0002 |            |                | CB_STL<4:0>          |           |            |            |            | I2C_MAS_EN | 08         | SPF_CONF   |
| COMM_CONF2 | 0x0003 | COMN_TX_DI | COMS_TX_DI     |                      |           | STACK_RESF | P_CMD<5:0> |            |            | 00         | SPF_CONF   |
| сомм_то    | 0x0004 | LCTO_S     | EL<1:0>        |                      | LONG<2:0> |            |            | SHORT<2:0> |            | ВВ         | SF_CONF    |
| COW_DET    | 0x0005 |            |                |                      |           |            | C_OW_T     | DIS<3:0>   |            | 00         | LF_SM_CONF |
| GAP_CMP1   | 0x0006 | GF         | PIO_GAP_THR<2: | 0> CELL_GAP_THR<4:0> |           |            |            |            | 00         | LF_SM_CONF |            |
| GAP_CMP2   | 0x0007 |            |                | CELL_GAP_DEGL<4:0>   |           |            |            |            | 07         | LF_SM_CONF |            |
| ADC_CONF1  | 0x0008 |            | DLPF_FC<2:0>   |                      |           | ADC_CI     | LK<1:0>    | ADC_M      | ODE<2:0>   | 09         | SPF_CONF   |

| Name                   | Add    | D7                | D6                | D5                | D4                | D3                 | D2                 | D1                | D0                | Default | Block      |
|------------------------|--------|-------------------|-------------------|-------------------|-------------------|--------------------|--------------------|-------------------|-------------------|---------|------------|
| ADC_CONF2              | 0x0009 |                   | CH_TOP_           | STL<3:0>          |                   |                    | CH_STL<3:0>        |                   |                   | 55      | SPF_CONF   |
| ADC_CONF3              | 0x000A |                   | CH_BOT_           | STL<3:0>          |                   |                    | ADC_CHP_EN         | CH_D              | T<1:0>            | 55      | SPF_CONF   |
| ADC_CONF4              | 0x000B | GPIO7_REF_S<br>EL | GPIO6_<br>REF_SEL | GPIO5_<br>REF_SEL | GPIO4_<br>REF_SEL | GPIO3_<br>REF_SEL  | GPIO2_<br>REF_SEL  | GPIO1_<br>REF_SEL | GPIOO_<br>REF_SEL | 00      | SPF_CONF   |
| ADC_CONF5              | 0x000C |                   |                   |                   |                   | GPIO11_<br>REF_SEL | GPIO10_<br>REF_SEL | GPIO9_<br>REF_SEL | GPIO8_<br>REF_SEL | 00      | SPF_CONF   |
| MON_CONF               | 0x000D |                   |                   | MON_WAKE_         | _PERIOD<5:0>      |                    |                    |                   | MON_WAKE_<br>EN   | 45      | SF_CONF    |
| OVUV_OTUT<br>_CONF1    | 0x000E | OVUV_OTUT<br>_EN  |                   |                   |                   | (                  | OVUV_DEGL<4:0      | >                 |                   | 80      | LF_SM_CONF |
| OVUV_OTUT<br>_CONF2    | 0x000F |                   |                   |                   |                   | OV_THR<6:0>        |                    |                   |                   | 60      | LF_SM_CONF |
| OVUV_OTUT<br>_CONF3    | 0x0010 |                   |                   |                   |                   | UV_THR <6:0>       |                    |                   |                   | 60      | LF_SM_CONF |
| OVUV_OTUT<br>_CONF4    | 0x0011 |                   | 0                 | Γ_PACK_THR<4:     | 0>                |                    | U                  | Γ_PACK_THR<2:     | 0>                | 7E      | LF_SM_CONF |
| OVUV_OTUT<br>_CONF5    | 0x0012 |                   | 0                 | T_PCB_THR<4:0     | )>                |                    | U                  | T_PCB_THR<2:0     | )>                | 7E      | LF_SM_CONF |
| OVUV_OTUT<br>_CONF6    | 0x0013 | GPIO7_THR_<br>SEL | GPIO6_THR_<br>SEL | GPIO5_THR_<br>SEL | GPIO4_THR_<br>SEL | GPIO3_THR_<br>SEL  | GPIO2_THR_<br>SEL  | GPIO1_THR_<br>SEL | GPIOO_THR_<br>SEL | 00      | LF_SM_CONF |
| OVUV_OTUT<br>_CONF7    | 0x0014 |                   |                   |                   |                   | GPIO11_THR<br>_SEL | GPIO10_THR<br>_SEL | GPIO9_THR_<br>SEL | GPIO8_THR_<br>SEL | 00      | LF_SM_CONF |
| CB_CONF1               | 0x0015 |                   | CB_F              | ROT_PACK_THR      | <4:0>             | I.                 |                    | CB_DUTY<2:0>      | I.                | 7F      | LF_SM_CONF |
| CB_CONF2               | 0x0016 |                   | CB_               | ROT_PCB_THR<      | 4:0>              |                    |                    | CB_PERIOD<2:0     | >                 | 78      | LF_SM_CONF |
| CB_CONF3               | 0x0017 |                   | CB_JOT_           | ΓHR<3:0>          |                   | ROT_PAUSE_<br>EN   | ADC_PAUSE_<br>EN   | JOT_PAUSE_E<br>N  | FLT_STOP_EN       | 00      | LF_SM_CONF |
| TWARN_CONF             | 0x0018 |                   |                   |                   |                   |                    | Т                  | WARN_THR<2:0      | )>                | 03      | LF_SM_CONF |
| GPIO_PUPD_EN1          | 0x0019 | GPIO7             | GPIO6             | GPIO5             | GPIO4             | GPIO3              | GPIO2              | GPIO1             | GPIO0             | 00      | SPF_CONF   |
| GPIO_PUPD_EN2          | 0x001A |                   |                   |                   |                   | GPIO11             | GPIO10             | GPIO9             | GPIO8             | 00      | SPF_CONF   |
| GPIO_ASDIN_EN1         | 0x001B | GPIO7             | GPIO6             | GPIO5             | GPIO4             | GPIO3              | GPIO2              | GPIO1             | GPIO0             | 00      | SPF_CONF   |
| GPIO_ASDIN_EN2         | 0x001C |                   |                   |                   |                   | GPIO11             | GPIO10             | GPIO9             | GPIO8             | 00      | SPF_CONF   |
| GPIO_WEAK_PUPD<br>_EN1 | 0x001D | GPIO7             | GPIO6             | GPIO5             | GPIO4             | GPIO3              | GPIO2              | GPIO1             | GPIO0             | 00      | SPF_CONF   |
| GPIO_WEAK_PUPD<br>_EN2 | 0x001E |                   |                   |                   |                   | GPIO11             | GPIO10             | GPIO9             | GPIO8             | 00      | SPF_CONF   |
| FLT_SUM_MSK            | 0x0100 |                   |                   |                   | COW_FLT_M<br>SK   | SYS_FLT_MSK        | GAP_FLT_MS<br>K    | OTUT_FLT_M<br>SK  | OVUV_FLT_M<br>SK  | 00      | SF_CONF    |
| COW_FLT_MSK1           | 0x0101 | C7_MSK            | C6_MSK            | C5_MSK            | C4_MSK            | C3_MSK             | C2_MSK             | C1_MSK            | CO_MSK            | 00      | LF_SM_CONF |
| COW_FLT_MSK2           | 0x0102 | C15_MSK           | C14_MSK           | C13_MSK           | C12_MSK           | C11_MSK            | C10_MSK            | C9_MSK            | C8_MSK            | 00      | LF_SM_CONF |
| COW_FLT_MSK3           | 0x0103 |                   |                   |                   |                   |                    | C18_MSK            | C17_MSK           | C16_MSK           | 00      | LF_SM_CONF |
| OV_FLT_MSK1            | 0x0104 | CH8_MSK           | CH7_MSK           | CH6_MSK           | CH5_MSK           | CH4_MSK            | CH3_MSK            | CH2_MSK           | CH1_MSK           | 00      | SF_CONF    |
| OV_FLT_MSK2            | 0x0105 | CH16_MSK          | CH15_MSK          | CH14_MSK          | CH13_MSK          | CH12_MSK           | CH11_MSK           | CH10_MSK          | CH9_MSK           | 00      | SF_CONF    |
| OV_FLT_MSK3            | 0x0106 |                   |                   |                   |                   |                    |                    | CH18_MSK          | CH17_MSK          | 00      | SF_CONF    |
| UV_FLT_MSK1            | 0x0107 | CH8_MSK           | CH7_MSK           | CH6_MSK           | CH5_MSK           | CH4_MSK            | CH3_MSK            | CH2_MSK           | CH1_MSK           | 00      | SF_CONF    |
| UV_FLT_MSK2            | 0x0108 | CH16_MSK          | CH15_MSK          | CH14_MSK          | CH13_MSK          | CH12_MSK           | CH11_MSK           | CH10_MSK          | CH9_MSK           | 00      | SF_CONF    |
| UV_FLT_MSK3            | 0x0109 |                   |                   |                   |                   |                    |                    | CH18_MSK          | CH17_MSK          | 00      | SF_CONF    |
| CELL_GAP_FLT_MS        | 0x010A | CH8_MSK           | CH7_MSK           | CH6_MSK           | CH5_MSK           | CH4_MSK            | CH3_MSK            | CH2_MSK           | CH1_MSK           | 00      | LF_SM_CONF |

| Name                  | Add               | D7                  | D6              | D5               | D4                | D3                   | D2                 | D1                 | D0                   | Default | Block      |
|-----------------------|-------------------|---------------------|-----------------|------------------|-------------------|----------------------|--------------------|--------------------|----------------------|---------|------------|
| K1                    |                   |                     |                 |                  |                   |                      |                    |                    |                      |         |            |
| CELL_GAP_FLT_MS<br>K2 | 0x010B            | CH16_MSK            | CH15_MSK        | CH14_MSK         | CH13_MSK          | CH12_MSK             | CH11_MSK           | CH10_MSK           | CH9_MSK              | 00      | LF_SM_CONF |
| CELL_GAP_FLT_MS<br>K3 | 0x010C            |                     |                 |                  |                   |                      |                    | CH18_MSK           | CH17_MSK             | 00      | LF_SM_CONF |
| GPIO_GAP_FLT_M<br>SK1 | 0x010D            | GPIO7_MSK           | GPIO6_MSK       | GPIO5_MSK        | GPIO4_MSK         | GPIO3_MSK            | GPIO2_MSK          | GPIO1_MSK          | GPIO0_MSK            | 00      | LF_SM_CONF |
| GPIO_GAP_FLT_M<br>SK2 | 0x010E            |                     |                 |                  |                   | GPIO11_MSK           | GPIO10_MSK         | GPIO9_MSK          | GPIO8_MSK            | 00      | LF_SM_CONF |
| OT_FLT_MSK1           | 0x010F            | GPIO7_MSK           | GPIO6_MSK       | GPIO5_MSK        | GPIO4_MSK         | GPIO3_MSK            | GPIO2_MSK          | GPIO1_MSK          | GPIO0_MSK            | 00      | SF_CONF    |
| OT_FLT_MSK2           | 0x0110            |                     |                 |                  |                   | GPIO11_MSK           | GPIO10_MSK         | GPIO9_MSK          | GPIO8_MSK            | 00      | SF_CONF    |
| UT_FLT_MSK1           | 0x0111            | GPIO7_MSK           | GPIO6_MSK       | GPIO5_MSK        | GPIO4_MSK         | GPIO3_MSK            | GPIO2_MSK          | GPIO1_MSK          | GPIO0_MSK            | 00      | SF_CONF    |
| UT_FLT_MSK2           | 0x0112            |                     |                 |                  |                   | GPIO11_MSK           | GPIO10_MSK         | GPIO9_MSK          | GPIO8_MSK            | 00      | SF_CONF    |
| SYS_FLT_MSK1          | 0x0113            |                     |                 |                  |                   | TBYTE_FAST_<br>MSK   | TBYTE_TO_M<br>SK   | FCOMM_FLT<br>_MSK  | FR_CRC_MSK           | 00      | LF_SM_CONF |
| SYS_FLT_MSK2          | 0x0114            | TWARN_MSK           | AGND_OW_<br>MSK | CONF_CRC_<br>MSK | MTP_CRC_M<br>SK   | CP_OV_MSK            | CP_UV_MSK          | VAA_OV_MS<br>K     | VAA_UV_MS<br>K       | 00      | LF_SM_CONF |
| SYS_FLT_MSK3          | 0x0115            |                     |                 | VDD_OV_MS<br>K   | VDD_UV_MS<br>K    | CLK_256K_O<br>KB_MSK | VDD_OKB_M<br>SK    | VAA_OKB_M<br>SK    | LCTO_SD_MS<br>K      | 00      | SF_CONF    |
| SYS_FLT_MSK4          | 0x0116            | CB_CONF_FL<br>T_MSK | SCTO_MSK        | LCTO_MSK         |                   | RX_FIFO_OF_<br>MSK   | TX_FIFO_OF_<br>MSK | TX_FIFO_UF_<br>MSK | CMP_FLT_MS<br>K      | 00      | SF_CONF    |
| SYS_FLT_MSK5          | 0x0117            |                     |                 |                  |                   |                      | HBFAST_MSK         | HBTO_MSK           | FLT_TONE_D<br>ET_MSK | 00      | SF_CONF    |
| MTP_ADR_MANU          | 0x1FFB            |                     |                 |                  | A                 | ADR_MANU<6:0         | >                  |                    |                      | Х       | SPF_FUNC   |
| MTP_DIN_MANU          | 0x1FFC            |                     |                 |                  | DIN_MA            | NU<7:0>              |                    |                    |                      | Х       | SPF_FUNC   |
| MTP_DOUT              | 0x1FFD            |                     |                 |                  | DOUT              | T<7:0>               |                    |                    |                      | Х       | SPF_FUNC   |
| MTP_TEST              | 0x1FFE            | CLEN                | CS_MANU         | MANU             | SRL               | MRGN                 | RD_MANU            | WR_MANU            | HVEN                 | Х       | SPF_FUNC   |
| MTP_CTRL              | 0x1FFF            |                     |                 |                  | ECED              | WR_NVM               |                    |                    | BUSY                 | Х       | SPF_FUNC   |
| TM_REGn<br>(n=1-10)   | 0x0800-<br>0x0809 |                     |                 |                  |                   |                      |                    |                    |                      | Х       | TM         |
| TRIM_ADC              | 0x1000            |                     |                 |                  |                   |                      |                    |                    |                      | Х       | TRIM       |
|                       |                   |                     |                 |                  |                   |                      |                    |                    |                      | Х       | TRIM       |
| TRIM_ANA              |                   |                     |                 |                  |                   |                      |                    |                    |                      | Х       | TRIM       |
| XY_LOT                |                   |                     |                 |                  |                   |                      |                    |                    |                      | Х       | TRIM       |
| TRIM_CRC              | 0x107F            |                     |                 |                  |                   |                      |                    |                    |                      | Х       | TRIM       |
| CONF_CRC_H            | 0x2000            |                     |                 |                  | CRC<              | 15:8>                |                    |                    |                      | 00      | LF_SM_FUNC |
| CONF_ CRC_L           | 0x2001            | CRC<7:0>            |                 |                  |                   |                      |                    |                    |                      | 00      | LF_SM_FUNC |
| CTRL1                 | 0x2002            | SRSTB               | DIR_SEL         |                  | WAKE_TONE<br>_GEN | STA_TONE_G<br>EN     | SD_TONE_GE<br>N    | TO_SD              | TO_SLEEP             | 80      | SPF_FUNC   |
| CTRL2                 | 0x2003            |                     |                 |                  |                   |                      | CMP_BIST_G<br>O    | ADD_W_EN           | SPI_DIR              | 00      | SF_FUNC    |
| ADC_CTRL              | 0x2004            | MON_WAKE_<br>GO     |                 |                  |                   |                      | FREEZE             | ADC_SGLE_G<br>O    | ADC_CNTI_G<br>O      | 00      | SPF_FUNC   |
| CB_CTRL               | 0x2005            |                     |                 |                  |                   |                      | CB_MANU            | CB_PAUSE           | CB_GO                | 00      | LF_SM_FUNC |
| CBFET_EN1             | 0x2006            | CH8                 | CH7             | СН6              | CH5               | CH4                  | CH3                | CH2                | CH1                  | 00      | LF_SM_FUNC |
| CBFET_EN2             | 0x2007            | CH16                | CH15            | CH14             | CH13              | CH12                 | CH11               | CH10               | СН9                  | 00      | LF_SM_FUNC |

| Name                      | Add    | D7      | D6      | D5      | D4      | D3      | D2      | D1      | D0              | Default | Block      |
|---------------------------|--------|---------|---------|---------|---------|---------|---------|---------|-----------------|---------|------------|
| CBFET_EN3                 | 0x2008 |         |         |         |         |         |         | CH18    | CH17            | 00      | LF_SM_FUNC |
| CB_TO_CHn_H<br>(n=1-18)   | 0x2009 | UNIT    |         |         |         |         |         | TO<     | :9:8>           | 83      | LF_SM_FUNC |
| CB_TO_CHn_L<br>(n=1-18)   | 0x200A |         |         | l       | TO<     | 7:0>    | 1       | 1       |                 | FF      | LF_SM_FUNC |
| GPIO_PUPD1                | 0x202D | GPIO7   | GPIO6   | GPIO5   | GPIO4   | GPIO3   | GPIO2   | GPIO1   | GPIO0           | 00      | SF_FUNC    |
| GPIO_PUPD2                | 0x202E |         |         |         |         | GPIO11  | GPIO10  | GPIO9   | GPIO8           | 00      | SF_FUNC    |
| DIAG_CTRL                 | 0x2100 |         |         |         |         |         |         |         | C_OW_DET_<br>GO | 00      | LF_SM_FUNC |
| GPIO_WEAK_PUPD<br>1       | 0x2101 | GPIO7   | GPIO6   | GPIO5   | GPIO4   | GPIO3   | GPIO2   | GPIO1   | GPIO0           | 00      | SF_FUNC    |
| GPIO_WEAK_PUPD 2          | 0x2102 |         |         |         |         | GPIO11  | GPIO10  | GPIO9   | GPIO8           | 00      | SF_FUNC    |
| CS_EN_MANU1               | 0x2103 | CS7_EN  | CS6_EN  | CS5_EN  | CS4_EN  | CS3_EN  | CS2_EN  | CS1_EN  | CSO_EN          | 00      | SPF_FUNC   |
| CS_EN_MANU2               | 0x2104 | CS15_EN | CS14_EN | CS13_EN | CS12_EN | CS11_EN | CS10_EN | CS9_EN  | CS8_EN          | 00      | SPF_FUNC   |
| CS_EN_MANU3               | 0x2105 |         |         |         |         |         | CS18_EN | CS17_EN | CS16_EN         | 00      | SPF_FUNC   |
| I2C_MAS_CTRL              | 0x2200 | STOP    | RX      | SR      | ACK     |         |         |         | TX              | 00      | SF_FUNC    |
| I2C_TR                    | 0x2201 |         |         |         | DATA    | x<7:0>  |         |         |                 | 00      | SF_FUNC    |
| I2C_RD                    | 0x2202 |         |         |         | DATA    | x<7:0>  |         |         |                 | 00      | SF_FUNC    |
| RR_CNT_H                  | 0x3FFE |         |         |         | CNT<    | 15:8>   |         |         |                 | 00      | LF_SM_FUNC |
| RR_CNT_L                  | 0x3FFF |         |         |         | CNT     | <7:0>   |         |         |                 | 00      | LF_SM_FUNC |
| CHn_LFP_H<br>(n=1-18)     | 0x4000 |         |         |         |         |         |         |         |                 | 00      | SPF_FUNC   |
| CHn_ LFP_L<br>(n=1-18)    | 0x4001 |         |         |         |         |         |         |         |                 | 00      | SPF_FUNC   |
|                           |        |         |         |         |         |         |         |         |                 |         |            |
| AUX_CHn_LFP_H<br>(n=1-18) | 0x4024 |         |         |         |         |         |         |         |                 | 00      | LF_SM_FUNC |
| AUX_CHn_LFP_L<br>(n=1-18) | 0x4025 |         |         |         |         |         |         |         |                 | 00      | LF_SM_FUNC |
|                           |        |         |         |         |         |         |         |         |                 |         |            |
| CHn_H<br>(n=1-18)         | 0x4048 |         |         |         |         |         |         |         |                 | 00      | LF_SM_FUNC |
| CHn_L<br>(n=1-18)         | 0x4049 |         |         |         |         |         |         |         |                 | 00      | LF_SM_FUNC |
|                           |        |         |         |         |         |         |         |         |                 |         |            |
| AUX_CHn_H<br>(n=1-18)     | 0x406C |         |         |         |         |         |         |         |                 | 00      | SF_FUNC    |
| AUX_CHn_L<br>(n=1-18)     | 0x404D |         |         |         |         |         |         |         |                 | 00      | SF_FUNC    |
|                           |        |         |         |         |         |         |         |         |                 |         |            |
| GPIOn_H<br>(n=0-11)       | 0x4090 |         |         |         |         |         |         |         |                 | 00      | SPF_FUNC   |
| GPIOn_L<br>(n=0-11)       | 0x4091 |         |         |         |         |         |         |         |                 | 00      | SPF_FUNC   |
|                           |        |         |         |         |         |         |         |         |                 |         |            |
| AUX_GPIOn_H<br>(n=0-11)   | 0x40A8 |         |         |         |         |         |         |         |                 | 00      | LF_SM_FUNC |

| Name                    | Add    | D7    | D6    | D5    | D4      | D3         | D2      | D1       | D0       | Default | Block      |  |  |
|-------------------------|--------|-------|-------|-------|---------|------------|---------|----------|----------|---------|------------|--|--|
| AUX_GPIOn_L<br>(n=0-11) | 0x40A9 |       |       |       |         |            |         |          |          |         |            |  |  |
|                         |        |       |       |       |         |            |         |          |          |         |            |  |  |
| VPTAT_H                 | 0x40C0 |       |       |       | 00      | LF_SM_FUNC |         |          |          |         |            |  |  |
| VPTAT_L                 | 0x40C1 |       |       |       |         |            |         |          |          | 00      | LF_SM_FUNC |  |  |
| BG_H                    | 0x40C2 |       |       |       | 00      | LF_SM_FUNC |         |          |          |         |            |  |  |
| BG_L                    | 0x40C3 |       |       |       |         |            |         |          |          | 00      | LF_SM_FUNC |  |  |
| BG2_H                   | 0x40C4 |       |       |       |         |            |         |          |          | 00      | LF_SM_FUNC |  |  |
| BG2_L                   | 0x40C5 |       |       |       |         |            |         |          |          | 00      | LF_SM_FUNC |  |  |
| FR_CNT_H                | 0x5000 |       |       |       | CNT<    | 15:8>      |         |          |          | 00      | LF_SM_FUNC |  |  |
| FR_CNT_L                | 0x5001 |       |       |       | CNT     | <7:0>      |         |          |          | 00      | LF_SM_FUNC |  |  |
| GPIO_DIN1               | 0x5002 | GPIO7 | GPIO6 | GPIO5 | GPIO4   | GPIO3      | GPIO2   | GPIO1    | GPIO0    | 00      | SF_FUNC    |  |  |
| GPIO_DIN2               | 0x5003 |       |       |       |         | GPIO11     | GPIO10  | GPIO9    | GPIO8    | 00      | SF_FUNC    |  |  |
| CB_CH_EN_FULL_<br>DUTY1 | 0x5004 | CH8   | CH7   | CH6   | CH5     | CH4        | CH3     | CH2      | CH1      | 00      | SF_FUNC    |  |  |
| CB_CH_EN_FULL_<br>DUTY2 | 0x5005 | CH16  | CH15  | CH14  | CH13    | CH12       | CH11    | CH10     | СН9      | 00      | SF_FUNC    |  |  |
| CB_CH_EN_FULL_<br>DUTY3 | 0x5006 |       |       |       |         |            |         | CH18     | CH17     | 00      | SF_FUNC    |  |  |
| CB_ODD_CNT_H            | 0x5007 |       |       |       | CNT<    | 15:8>      |         |          |          | 00      | SF_FUNC    |  |  |
| CB_ODD_CNT_L            | 0x5008 |       |       |       | CNT     | <7:0>      |         |          |          | 00      | SF_FUNC    |  |  |
| CB_EVEN_CNT_H           | 0x5009 |       |       |       | CNT<    | 15:8>      |         |          |          | 00      | SF_FUNC    |  |  |
| CB_EVEN_CNT_L           | 0x500A |       |       |       | CNT     | <7:0>      |         |          |          | 00      | SF_FUNC    |  |  |
| FLT_SUM                 | 0x5100 |       |       |       | COW_FLT | SYS_FLT    | GAP_FLT | OTUT_FLT | OVUV_FLT | 00      | FLT_SUM    |  |  |
| COW_FLT1                | 0x5101 | C7    | C6    | C5    | C4      | C3         | C2      | C1       | CO       | 00      | FLT_BIT    |  |  |
| COW_FLT2                | 0x5102 | C15   | C14   | C13   | C12     | C11        | C10     | C9       | C8       | 00      | FLT_BIT    |  |  |
| COW_FLT3                | 0x5103 |       |       |       |         |            | C18     | C17      | C16      | 00      | FLT_BIT    |  |  |
| OV_FLT1                 | 0x5104 | CH8   | CH7   | CH6   | CH5     | CH4        | CH3     | CH2      | CH1      | 00      | FLT_BIT    |  |  |
| OV_FLT2                 | 0x5105 | CH16  | CH15  | CH14  | CH13    | CH12       | CH11    | CH10     | CH9      | 00      | FLT_BIT    |  |  |
| OV_FLT3                 | 0x5106 |       |       |       |         |            |         | CH18     | CH17     | 00      | FLT_BIT    |  |  |
| UV_FLT1                 | 0x5107 | CH8   | CH7   | CH6   | CH5     | CH4        | CH3     | CH2      | CH1      | 00      | FLT_BIT    |  |  |
| UV_FLT2                 | 0x5108 | CH16  | CH15  | CH14  | CH13    | CH12       | CH11    | CH10     | CH9      | 00      | FLT_BIT    |  |  |
| UV_FLT3                 | 0x5109 |       |       |       |         |            |         | CH18     | CH17     | 00      | FLT_BIT    |  |  |
| CELL_GAP_FLT1           | 0x510A | CH8   | CH7   | CH6   | CH5     | CH4        | CH3     | CH2      | CH1      | 00      | FLT_BIT    |  |  |
| CELL_GAP_FLT2           | 0x510B | CH16  | CH15  | CH14  | CH13    | CH12       | CH11    | CH10     | CH9      | 00      | FLT_BIT    |  |  |
| CELL_GAP_FLT3           | 0x510C |       |       |       |         |            |         | CH18     | CH17     | 00      | FLT_BIT    |  |  |
| GPIO_GAP_FLT1           | 0x510D | GPIO7 | GPIO6 | GPIO5 | GPIO4   | GPIO3      | GPIO2   | GPIO1    | GPIO0    | 00      | FLT_BIT    |  |  |
| GPIO_GAP_FLT2           | 0x510E |       |       |       |         | GPIO11     | GPIO10  | GPIO9    | GPIO8    | 00      | FLT_BIT    |  |  |
| OT_FLT1                 | 0x510F | GPIO7 | GPIO6 | GPIO5 | GPIO4   | GPIO3      | GPIO2   | GPIO1    | GPIO0    | 00      | FLT_BIT    |  |  |
| OT_FLT2                 | 0x5110 |       |       |       |         | GPIO11     | GPIO10  | GPIO9    | GPIO8    | 00      | FLT_BIT    |  |  |

| Name                   | Add    | D7              | D6      | D5       | D4      | D3               | D2         | D1         | D0               | Default | Block   |
|------------------------|--------|-----------------|---------|----------|---------|------------------|------------|------------|------------------|---------|---------|
| UT_FLT1                | 0x5111 | GPIO7           | GPIO6   | GPIO5    | GPIO4   | GPIO3            | GPIO2      | GPIO1      | GPIO0            | 00      | FLT_BIT |
| UT_FLT2                | 0x5112 |                 |         |          |         | GPIO11           | GPIO10     | GPIO9      | GPIO8            | 00      | FLT_BIT |
| SYS_FLT1               | 0x5113 |                 |         |          |         | TBYTE_FAST       | TBYTE_TO   | FCOMM_FLT  | FR_CRC           | 00      | FLT_BIT |
| SYS_FLT2               | 0x5114 | TWARN           | AGND_OW | CONF_CRC | MTP_CRC | CP_OV            | CP_UV      | VAA_OV     | VAA_UV           | 00      | FLT_BIT |
| SYS_FLT3               | 0x5115 |                 |         | VDD_OV   | VDD_UV  | CLK_256K_O<br>KB | VDD_OKB    | VAA_OKB    | LCTO_SD          | 00      | FLT_BIT |
| SYS_FLT4               | 0x5116 | CB_CONF_FL<br>T | SCTO    | LCTO     |         | RX_FIFO_OF       | TX_FIFO_OF | TX_FIFO_UF | CMP_FLT          | 00      | FLT_BIT |
| SYS_FLT5               | 0x5117 |                 |         |          |         |                  | HBFAST     | НВТО       | FLT_TONE_D<br>ET | 00      | FLT_BIT |
| TM_KEY 0x6000 KEY<7:0> |        |                 |         |          |         |                  |            |            |                  | 00      | SF_FUNC |

Table2 Register Map2

# **Functional Details**

# **Block Diagram**

The following diagram shows the COMM\_REG architecture and internal modules and connections.



Figure1 COMM\_REG diagram

# **Module input/output list**

| Name              | Dir | Width | Description                                                                | duration              |
|-------------------|-----|-------|----------------------------------------------------------------------------|-----------------------|
| DEV_ADD           | О   | 7     | Device address                                                             | Level(CLK_REG domain) |
| COMN_TX_DIS       | О   | 1     | N port transmission disable                                                | Level(CLK_REG domain) |
| COMS_TX_DIS       | О   | 1     | S port transmission disable                                                | Level(CLK_REG domain) |
| SPI_DIR_REG       | О   | 1     | 1: spi replace N port; 0: spi replace S port                               | Level(CLK_REG domain) |
| WAKE_TONE_GEN     | О   | 1     | Wake tone generation                                                       | Level(CLK_REG domain) |
| FREEZE            | О   | 1     | ADC results freeze for reading                                             | Level(CLK_REG domain) |
| DIR_SEL           | О   | 1     | Indicate the receiving data direction 1: rx from N port; 0: rx from S port | Level(CLK_REG domain) |
| STA_TONE_GEN      | О   | 1     | STA tone generation                                                        | Level(CLK_REG domain) |
| TO_SD             | О   | 1     | For analog                                                                 | Level(CLK_REG domain) |
| TO_SLEEP          | О   | 1     | For analog                                                                 | Level(CLK_REG domain) |
| read_data         | О   | 8     | Read data for daisy chain or SPI interface                                 | Level(CLK_REG domain) |
| reg0000~reg001E   | О   | 8*31  | Register bits for CONF_CRC                                                 | Level(CLK_REG domain) |
| reg0100~reg0117   | О   | 8*24  | Register bits for CONF_CRC                                                 | Level(CLK_REG domain) |
| D2A_TOP_DEV       | О   | 1     | Top device in system                                                       | Level(CLK_REG domain) |
| D2A_LCTO_SEL01    | О   | 1     | For analog                                                                 | Level(CLK_REG domain) |
| D2A_LCTO_SEL10    | О   | 1     | For analog                                                                 | Level(CLK_REG domain) |
| PROG_LCTO         | О   | 3     | Program bits for Long timeout                                              | Level(CLK_REG domain) |
| PROG_SCTO         | О   | 3     | Program bits for Long timeout                                              | Level(CLK_REG domain) |
| DLPF_FC_REG       | О   | 3     | Digital low pass filter stage setting                                      | Level(CLK_REG domain) |
| SD_TONE_GEN       | О   | 1     | Shut down tone generation                                                  | Level(CLK_REG domain) |
| ADC_SGLE_GO       | О   | 1     | ADC single go                                                              | Level(CLK_REG domain) |
| ADC_CNTI_GO       | О   | 1     | ADC continuous go                                                          | Level(CLK_REG domain) |
| MON_EN_REG        | О   | 1     | Monitor enable bit                                                         | Level(CLK_REG domain) |
| MON_WAKE_GO       | О   | 1     | Monitor wake go                                                            | Level(CLK_REG domain) |
| ADR_MANU          | О   | 7     | Manual address setting, for MTP_TOP                                        | Level(CLK_REG domain) |
| CLEN              | О   | 1     | For MTP interface                                                          | Level(CLK_REG domain) |
| CS_MANU           | О   | 1     | Manual CS setting, for MTP_TOP                                             | Level(CLK_REG domain) |
| MANU              | О   | 1     | MANU mode for ICELL test                                                   | Level(CLK_REG domain) |
| SRL               | О   | 1     | For MTP_TOP                                                                | Level(CLK_REG domain) |
| MRGN              | О   | 1     | For MTP_TOP                                                                | Level(CLK_REG domain) |
| RD_MANU           | О   | 1     | Manual RD setting, for MTP_TOP                                             | Level(CLK_REG domain) |
| WR_MANU           | О   | 1     | Manual WR setting, for MTP_TOP                                             | Level(CLK_REG domain) |
| HVEN              | О   | 1     | For MTP_TOP                                                                | Level(CLK_REG domain) |
| wr_nvm            | О   | 1     | Write MTP                                                                  | Level(CLK_REG domain) |
| DIN               | О   | 1     | DATA from MTP                                                              | Level(CLK_REG domain) |
| GainErr_code_comm | О   | 12    | TRIM_ADC                                                                   | Level(CLK_REG domain) |
| ADC_VCM_GAIN_EN   | О   | 1     | TRIM_ADC                                                                   | Level(CLK_REG domain) |
| ADC_TEMP_COM_EN   | О   | 1     | TRIM_ADC                                                                   | Level(CLK_REG domain) |

| trim_logic_en            | О | 1     | For TRIM_LOGIC     | Level(CLK_REG domain) |
|--------------------------|---|-------|--------------------|-----------------------|
| GainErr_code_Cell1~18    | О | 7*18  | TRIM_ADC           | Level(CLK_REG domain) |
| GainErr_code_GPIO        | О | 12    | TRIM_ADC           | Level(CLK_REG domain) |
| GainErr_code_VPTAT       | О | 12    | TRIM_ADC           | Level(CLK_REG domain) |
| ADC_TEMP_code_H          | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| ADC_TEMP_code_L          | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| Vos_code_comm            | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| Vos_code_cell1~18        | О | 6*18  | TRIM_ADC           | Level(CLK_REG domain) |
| Vos_code_GPIO            | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| ALG_GAINERR1             | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| Vcm_code_comm            | О | 7     | TRIM_ADC           | Level(CLK_REG domain) |
| GainErr_code_B_comm      | О | 12    | TRIM_ADC           | Level(CLK_REG domain) |
| AUX_VCM_GAIN_EN          | О | 1     | TRIM_ADC           | Level(CLK_REG domain) |
| AUX_TEMP_COM_EN          | О | 1     | TRIM_ADC           | Level(CLK_REG domain) |
| GainErr_code_B_Cell1~18  | О | 7*18  | TRIM_ADC           | Level(CLK_REG domain) |
| GainErr_code_B_GPIO      | О | 12    | TRIM_ADC           | Level(CLK_REG domain) |
| GainErr_code_B_VPTAT     | О | 12    | TRIM_ADC           | Level(CLK_REG domain) |
| AUX_TEMP_code_B_H        | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| AUX_TEMP_code_B_L        | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| Vos_code_B_comm          | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| Vos_code_B_cell1~18      | О | 6*18  | TRIM_ADC           | Level(CLK_REG domain) |
| Vos_code_B_GPIO          | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| ALG_GAINERR2             | О | 8     | TRIM_ADC           | Level(CLK_REG domain) |
| Vcm_code_B_comm          | О | 7     | TRIM_ADC           | Level(CLK_REG domain) |
| Reg1000~107F             | О | 8*128 | For MTP_CRC        | Level(CLK_REG domain) |
| CONF_CRC                 | О | 16    | For CONF_CRC check | Level(CLK_REG domain) |
| TM_REG1~10               | О | 8*10  | Regs for test mode | Level(CLK_REG domain) |
| CELL_OV_THRESH_REG       | О | 7     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| CELL_UV_THRESH_REG       | О | 7     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| GPIO_OTUT_THRESH_SEL_REG | О | 12    | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| GPIO_OT_PACK_THRESH_REG  | О | 5     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| GPIO_OT_PCB_THRESH_REG   | О | 5     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| GPIO_UT_PACK_THRESH_REG  | О | 3     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| GPIO_UT_PCB_THRESH_REG   | О | 3     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| CB_OT_PACK_THRESH_REG    | О | 5     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| CB_OT_PCB_THRESH_REG     | 0 | 5     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| TWARN_THRESH_REG         | О | 3     | For OVUV_OTUT_CMP  | Level(CLK_REG domain) |
| GPIO_PUPD                | О | 12    | For analog         | Level(CLK_REG domain) |
| GPIO_PUPD_EN             | О | 12    | For analog         | Level(CLK_REG domain) |
| GPIO_AS_IN_EN            | О | 12    | For analog         | Level(CLK_REG domain) |
| WEAK_PUPD_EN             | О | 12    | For analog         | Level(CLK_REG domain) |
| WEAK_PUPD                | О | 12    | For analog         | Level(CLK_REG domain) |

| CS_EN_MANU          | О | 19 | For analog                                                                                        | Level(CLK_REG domain)      |
|---------------------|---|----|---------------------------------------------------------------------------------------------------|----------------------------|
| OVUV_OTUT_EN_REG    | О | 1  | For OVUV_OTUT_CMP                                                                                 | Level(CLK_REG domain)      |
| OVUV_DEGL_REG       | О | 5  | For OVUV_OTUT_CMP                                                                                 | Level(CLK_REG domain)      |
| MON_WAKE_PERIOD_REG | 0 | 6  | For CYC_WAKE                                                                                      | Level(CLK_REG domain)      |
| CELL_GAP_THRESH_REG | О | 5  | For GAP_CMP                                                                                       | Level(CLK_REG domain)      |
| OTH_GAP_THRESH_REG  | О | 3  | For GAP_CMP                                                                                       | Level(CLK_REG domain)      |
| CELL_CAP_DEGL_REG   | О | 5  | For GAP_CMP                                                                                       | Level(CLK_REG domain)      |
| CH_TOP_STL_REG      | О | 4  | ADC_SETTING                                                                                       | Level(CLK_REG domain)      |
| CH_STL_REG          | О | 4  | ADC_SETTING                                                                                       | Level(CLK_REG domain)      |
| CH_BOT_STL_REG      | О | 4  | ADC_SETTING                                                                                       | Level(CLK_REG domain)      |
| ADC_MODE_REG        | О | 2  | ADC_SETTING                                                                                       | Level(CLK_REG domain)      |
| ADC_CLK_SET_REG     | О | 2  | ADC_SETTING                                                                                       | Level(CLK_REG domain)      |
| ADC_CHP_EN_REG      | О | 1  | ADC_SETTING                                                                                       | Level(CLK_REG domain)      |
| CH_DT_REG           | О | 2  | ADC_SETTING                                                                                       | Level(CLK_REG domain)      |
| STACK_RESPONSE      | О | 6  | Determine byte interval time in response frames                                                   | Level(CLK_REG domain)      |
| SOFT_RSTB_REG       | O | 1  | 0:Soft reset 1:not reset                                                                          | Level(CLK_REG domain)      |
| ADD_W_EN            | O | 1  | Indicating address identify frame                                                                 | Level(CLK_REG domain)      |
| DEV_NUM             | О | 7  | Device number from current device to the top device                                               | Level(CLK_REG domain)      |
| I2C_MAC_EN          | О | 1  | I2c master enable                                                                                 | Level(CLK_REG domain)      |
| i2c_sr              | О | 1  | For I2C_MAS to generate a restart condition                                                       | Level(CLK_REG domain)      |
| i2c_stop            | О | 1  | For I2C_MAS to generate a stop condition                                                          | Level(CLK_REG domain)      |
| i2c_tx              | О | 1  | For I2C_MAS to send data                                                                          | Level(CLK_REG domain)      |
| i2c_tx              | О | 1  | For I2C_MAS to receive data                                                                       | Level(CLK_REG domain)      |
| i2c_tx_data         | О | 8  | For I2C_MAS prepare data to send                                                                  | Level(CLK_REG domain)      |
| C_OW_DET_GO         | О | 1  | For C_OW_CTRL                                                                                     | Cleared by clr_C_OW_DET_GO |
| C_OW_TDIS_REG       | О | 4  | For C_OW_CTRL                                                                                     | Level(CLK_REG domain)      |
| BIST_GO             | О | 1  | For CMP_BIST_CTRL                                                                                 | Cleared by clr_BIST_GO     |
| CB_GO               | О | 1  | To start CB_CTRL and load CB_Setting_REG                                                          | Cleared by clr_CB_GO       |
| CB_MANU_PAUSE       | О | 1  | pause CB_CTRL                                                                                     | Level(CLK_REG domain)      |
| CB_SETTLE           | О | 5  | For RECLK_COMP: CB settle time                                                                    | Level(CLK_REG domain)      |
| CB_GO               | О | 1  | To start CB_CTRL and load CB_Setting_REG                                                          | Cleared by clr_CB_GO       |
| CB_PERIOD_REG       | О | 3  | in automatic mode, indicate odd/even<br>covert time, 5s-30min, 8steps<br>refer to competitor spec | Level(CLK_REG domain)      |
| CB_DUTY_REG         | О | 3  | duty of internal PWM, shall cover 12.5%-100%, 8steps period is 200ms                              | Level(CLK_REG domain)      |
| CB_MANUAL_REG       | О | 1  | CB mode select, 1: manual , 0:automatic                                                           | Level(CLK_REG domain)      |
| JOT_EN_REG          | О | 1  | enable JOT to pause CB_CTRL                                                                       | Level(CLK_REG domain)      |
| ADC_PAUSE_EN_REG    | О | 1  | enable ADC_EN to pause CB_CTRL                                                                    | Level(CLK_REG domain)      |
| GPIO_CBOT_EN_REG    | О | 1  | enable GPIO_CBOT to pause CB_CTRL                                                                 | Level(CLK_REG domain)      |

| FLT_STOP_EN_REG      | О | N/A   | enable FLT_WAKE to stop<br>CB_CTRL, stop CB_EN, and wait for<br>another CB_GO when FLT_WAKE is<br>"L" | Level(CLK_REG domain)  |
|----------------------|---|-------|-------------------------------------------------------------------------------------------------------|------------------------|
| CBFET_EN_REG         | О | 18    | CB_EN Input of 18 channels                                                                            | Level(CLK_REG domain)  |
| CB_TWARN_THRESH_REG  | О | 4     | after CB_GO,CB_CTRL output CB_TWARN_THRESH to analog, don't need other operation                      | Level(CLK_REG domain)  |
| CB_UNIT_REG          | О | 18    | unit of CB_TO_THRESH_REG                                                                              | Level(CLK_REG domain)  |
| CB_TO_THRESH_REG1-18 | О | 10*18 | CB threshold time about each channel                                                                  | Level(CLK_REG domain)  |
| X_FLT_SUM_REG        | О | 1*5   | Fault sum regs for FLT_LOGIC                                                                          | Level(CLK_REG domain)  |
| X_FLT_REG            | О | 1*143 | Fault bit regs for FLT_LOGIC                                                                          | Level(CLK_REG domain)  |
| TM_KEY               | О | 8     | For TM_KEY_CHECK                                                                                      | Level(CLK_REG domain)  |
| CLK_REG_SC           | I | 1     | Scan-mux result of 8MHz clock from CLK_32M                                                            | 8MHz                   |
| resetb_CLK           | I | 1     | Asynchronous reset signal(synchronously released)                                                     |                        |
| CLK_8M_256K_SC       | I | 1     | When CLK_32M is OK, use CLK_8M; otherwise use CLK_256K; after scanmux                                 | 8MHz or 256kHz         |
| resetb_CLK_OUT       | I | 1     | Asynchronous reset signal by CLK_OUT(synchronously released)                                          |                        |
| CLK_I2C_SC           | I | 1     | For I2C_CTRL(change CLK_REG to CLK_I2C domain)                                                        |                        |
| resetb_SR_CLK_I2C    | I | 1     | Asynchronous reset signal (synchronously released) with soft reset for I2C_CTRL                       |                        |
| SOFT_RSTB_32M        | I | 1     | Soft reset from RSTGEN                                                                                | Level(CLK_REG domain)  |
| SOFT_RSTB            | I | 1     | CLK_SLOW synced SOFT_RSTB_REG from u_SOFT_RSTB_sync                                                   | Level(CLK_SLOW domain) |
| pulse_2ms            | Ι | 1     |                                                                                                       |                        |
| ini_addr             | I | 16    | Initial address for writing                                                                           | Level(CLK_REG domain)  |
| reg_addr             | I | 16    | Register address for reading                                                                          | Level(CLK_REG domain)  |
| neg_rx_en            | Ι | 1     |                                                                                                       |                        |
| bytes                | I | 4     | Bytes number for successive writing                                                                   | Level(CLK_REG domain)  |
| wr_data              | I | 128   | Received data buffer                                                                                  | Level(CLK_REG domain)  |
| wr_update            | I | 1     | Write update time                                                                                     | Level(CLK_REG domain)  |
| SPI_EN               | I | 1     | 1:used as bridge 0:used as AFE                                                                        | Async(constant)        |
| rx_en_n              | I | 1     | Receive data from N port                                                                              | Level(CLK_32M domain)  |
| rx_en_s              | I | 1     | Receive data from S port                                                                              | Level(CLK_32M domain)  |
| dev_addr_dlv         | I | 1     | Device address identify delivery                                                                      | Level(CLK_REG domain)  |
| dev_addr0            | I | 8     | Device address                                                                                        | Level(CLK_REG domain)  |
| state_tx_bps         | I | 1     | tx_state is STATE_BYPASS                                                                              | Level(CLK_REG domain)  |
| state_rx_bps         | I | 1     | state is STATE_BYPASS                                                                                 | Level(CLK_REG domain)  |
| state_rx_init        | I | 1     | state is STATE_INIT                                                                                   | Level(CLK_REG domain)  |
| state_rx_cur_addr    | I | 1     | state is STATE_CUR_ADR                                                                                | Level(CLK_REG domain)  |
| FRAME_DONE           | О | 1     | A complete frame is received.                                                                         | Level(CLK_REG domain)  |
| FR_CRC_FLT           | 0 | 1     | Frame CRC fault                                                                                       | Level(CLK_REG domain)  |
| TWARN                | 0 | 1     | Fault input from u_OVUV_OTUT_CMP                                                                      | Level(CLK_SLOW domain) |

| load_done         | О | 1  | MTP load done                                                                                           | Level(CLK_REG domain) |
|-------------------|---|----|---------------------------------------------------------------------------------------------------------|-----------------------|
| DEV_ADD_LATCH     | О | 7  | Latched device address                                                                                  | constant              |
| DEV_NUM_LATCH     | О | 7  | Latched device number in the rest of the daisy chain                                                    | constant              |
| DIR_SEL_LATCH     | О | 1  | Latched direction seletion 1:data from N to S 0:data from S to N                                        | constant              |
| TOP_DEV_LATCH     | О | 1  | Latched top device information                                                                          | constant              |
| clr_ADC_GO        | О | 1  | Signal to clear 4 kinds of ADC_GO                                                                       |                       |
| clr_MON_WAKE_GO   | О | 1  | Signal to clear MON_WAKE_GO                                                                             | 1 CLK_SLOW            |
| clr_C_OW_DET_GO   | О | 1  | Signal to clear C_OW_DET_GO                                                                             | 1 CLK_SLOW            |
| RR_COUNTER        | I | 16 | Round-robin number, RR_COUNTER is frozen when FREEZE_DLY is detected, is cleared by ADC_GO_DLY is high. |                       |
| pos_HBFAST        | I | 1  | HB too fast condition is detected                                                                       | 1 CLK_256K            |
| pos_HBTO          | I | 1  | HB too slow(timeout) condition is detected                                                              | 1 CLK_256K            |
| clr_TO_SLEEP      | I | 1  | Signal to clear TO_SLEEP                                                                                | 2~3 CLK_SLOW          |
| clr_WAKE_TONE_GEN | I | 1  | Pulse for module u_COMM_REG to clear WAKE_TONE_GEN                                                      | 1 CLK_256K            |
| clr_STA_TONE_GEN  | I | 1  | Pulse for module u_COMM_REG to clear STA_TONE_GEN                                                       | 1 CLK_256K            |
| clr_SD_TONE_GEN   | I | 1  | Pulse for module u_COMM_REG to clear SD_TONE_GEN                                                        | 1 CLK_256K            |
| MISS              | I | 1  |                                                                                                         |                       |
| ORDER             | Ι | 1  |                                                                                                         |                       |
| SYNCT             | Ι | 1  |                                                                                                         |                       |
| SYNCD             | Ι | 1  |                                                                                                         |                       |
| BIT               | Ι | 1  |                                                                                                         |                       |
| RR                | Ι | 1  |                                                                                                         |                       |
| SOFB              | Ι | 1  |                                                                                                         |                       |
| IERR              | Ι | 1  |                                                                                                         |                       |
| TXDIS             | Ι | 1  |                                                                                                         |                       |
| SOF               | Ι | 1  |                                                                                                         |                       |
| UNEXP_C           | Ι | 1  |                                                                                                         |                       |
| UNEXP_R           | Ι | 1  |                                                                                                         |                       |
| CRC               | Ι | 1  |                                                                                                         |                       |
| CONFL             | Ι | 1  |                                                                                                         |                       |
| pos_TBYTE_FAST    | Ι | 1  | fault flag: receiving data is too fast                                                                  | 4 CLK_32M             |
| pos_TBYTE_TO      | I | 1  | fault flag: receiving data is too slow                                                                  | 4 CLK_32M             |
| FCOMM_FLT_IN      | I | 1  | Communication fault received from last device                                                           | Level(CLK_REG domain) |
| i2c_rx_data       | Ι | 8  | I2c received data                                                                                       | Level(CLK_I2C domain) |
| i2c_ack_out       | I | 1  | I2c acknowledge bit                                                                                     | Level(CLK_REG domain) |
| DOUT              | I | 8  | Data loaded from u_MTP                                                                                  | async                 |
| READ              | I | 1  | READ pulse from u_MTP_TOP                                                                               | Level(CLK_MTP domain) |
| idle_2h           | I | 1  | Mark the time for shadow registers to update with DOUT                                                  | 8 CLK_MTP             |
| clrb_wr_mtp       | I | 1  | Signal to clear WR_MTP                                                                                  | Level(CLK_MTP domain) |

| ADR                | I | 7     | Address for MTP_REG                                                      | Level(CLK_MTP domain)  |
|--------------------|---|-------|--------------------------------------------------------------------------|------------------------|
| WR_MTP             | Ι | 1     | MTP writing is on-going                                                  |                        |
| LCTO_SD_LATCH      | I | 1     | Analog latched LCTO_SD fault                                             | Async(constant)        |
| CLK_256K_OKB_LATCH | I | 1     | Analog latched CLK_256K not OK fault                                     | Async(constant)        |
| VDD_OKB_LATCH      | I | 1     | Analog latched VDD not OK fault                                          | Async(constant)        |
| VAA_OKB_LATCH      | I | 1     | Analog latched VAA not OK fault                                          | Async(constant)        |
| VDD_OV_LATCH       | I | 1     | Analog latched VDD OV fault                                              | Async(constant)        |
| VDD_UV_LATCH       | I | 1     | Analog latched VDD UV fault                                              | Async(constant)        |
| GPIO_HL            | I | 12    | From analog, read-only                                                   | Async                  |
| CELL_UV            | I | 18    | Cell UV fault                                                            | Level(CLK_SLOW domain) |
| CELL_OV            | I | 18    | Cell OV fault                                                            | Level(CLK_SLOW domain) |
| GPIO_UT            | I | 12    | GPIO UT fault                                                            | Level(CLK_SLOW domain) |
| GPIO_OT            | I | 12    | GPIO OT fault                                                            | Level(CLK_SLOW domain) |
| VAA_OV             | I | 1     | VAA OV fault from analog                                                 | Async                  |
| VAA_UV             | I | 1     | VAA UV fault from analog                                                 | Async                  |
| VDD_OV             | I | 1     | VDD OV fault from analog                                                 | Async                  |
| VDD_UV             | I | 1     | VDD UV fault from analog                                                 | Async                  |
| CP_OV              | I | 1     | CP OV fault from analog                                                  | Async                  |
| CP_UV              | I | 1     | CP UV fault from analog                                                  | Async                  |
| AGND_OW            | I | 1     | AGND OW fault from analog                                                | Async                  |
| SET_SCTO           | I | 1     | Short timeout                                                            | Level(CLK_REG domain)  |
| SET_LCTO           | I | 1     | Long timeout                                                             | Level(CLK_REG domain)  |
| TRIM_EN            | I | 1     | Trim enable                                                              | Level(CLK_REG domain)  |
| TMREG_EN           | I | 1     | Test mode reg enable                                                     | Level(CLK_REG domain)  |
| tx_add_reg_addr    | I | 1     | tx register address adds bytes end pulse                                 | 1 CLK_32M              |
| tx_state_addr      | I | 1     | tx_state is STATE_ADDR                                                   | Level(CLK_REG domain)  |
| ADC_CH1~18         | I | 16*18 | Trimmed ADC_CH data                                                      | Level(CLK_REG domain)  |
| ADC_GPIO1~12       | I | 16*12 | Trimmed ADC_GPIO data                                                    | Level(CLK_REG domain)  |
| ADC_VPTAT          | I | 1     | Trimmed ADC_VPTAT data                                                   | Level(CLK_REG domain)  |
| ADC_VBG            | I | 1     | Trimmed ADC_VBG data                                                     | Level(CLK_REG domain)  |
| ADC_VBG2           | I | 1     | Trimmed ADC_VBG2 data                                                    | Level(CLK_REG domain)  |
| ADC_LPF_CH1~18     | I | 16*18 | Trimmed ADC_CH data after LPF                                            | Level(CLK_REG domain)  |
| AUX_CH1~18         | I | 16*18 | Trimmed AUX_CH data                                                      | Level(CLK_REG domain)  |
| AUX_GPIO1~12       | I | 16*12 | Trimmed AUX_GPIO data                                                    | Level(CLK_REG domain)  |
| AUX_VPTAT          | I | 1     | Trimmed AUX_VPTAT data                                                   | Level(CLK_REG domain)  |
| AUX_VBG            | I | 1     | Trimmed AUX_VBG data                                                     | Level(CLK_REG domain)  |
| AUX_VBG2           | I | 1     | Trimmed AUX_VBG2 data                                                    | Level(CLK_REG domain)  |
| AUX_LPF_CH1~18     | I | 16*18 | Trimmed AUX_CH data after LPF                                            | Level(CLK_REG domain)  |
| CB_ODD_CNT         | I | 16    | odd/even is same in manual mode, is different in automatic mode, counter | Level(CLK_CB domain)   |

|                  |   |    | of odd group                                                                  |                        |
|------------------|---|----|-------------------------------------------------------------------------------|------------------------|
| CB_EVEN_CNT      | I | 16 | counter of even group                                                         | Level(CLK_CB domain)   |
| CB_EN_FULL_DUTY  | I | 18 | output CB_CH_EN with full duty                                                | Level(CLK_CB domain)   |
| FR_CNT           | I | 16 | Frame counter                                                                 | Level(CLK_REG domain)  |
| CMP_FLT          | I | 16 | Compare fault from u_CMP_BIST_CTRL                                            | Level(CLK_REG domain)  |
| RX_FIFO_OF       | I | 1  | TX FIFO overflow, when TX FIFO is full and daisy chain still write to TX FIFO | 1 CLK_REG_SC           |
| TX_FIFO_OF       | I | 1  | RXFIFO overflow, when RXFIFO is full and host still write to RXFIFO           | 1 CLK_REG_SC           |
| TX_FIFO_UF       | I | 1  | TXFIFO underflow, when FIFO is empty and read from FIFO                       | 1 CLK_REG_SC           |
| CONF_REG_CRC_FLT | I | 1  | Configure registers CRC fault                                                 | Level(CLK_SLOW domain) |
| MTP_REG_CRC_FLT  | I | 1  | MTP registers CRC fault                                                       | Level(CLK_SLOW domain) |
| FLT_TONE_DET     | I | 1  | Fault tone detected by analog                                                 | async                  |
| clr_BIST_GO      | I | 1  | Signal to reset BIST_GO                                                       |                        |
| clr_CB_GO        | Ι | 1  | output to clear CB_GO                                                         | >1 CLK_CB_SC           |
| CELL_GAP_FLT     | I | 18 | Over gap threshold flag of CELL1-<br>CELL18                                   | Level(CLK_SLOW domain) |
| OTH_GAP_FLT      | I | 12 | Over gap threshold flag of other channel                                      | Level(CLK_SLOW domain) |
| C_OW_FLT         | I | 19 | Over range flags                                                              | Level(CLK_REG domain)  |
| ECED             | I | 1  | MTP data corrected flag by ECC algorithm                                      | aysnc                  |
| CB_CONF_FLT      | I | 1  | >2 consecutive channels turn on in CBFET_EN                                   | 1 CLK_CB_SC            |
| BUSY             | I | 1  | MTP write on-going flag by u_MTP                                              | async                  |
| neg_response     | I | 1  | Negative edge of response                                                     | 1 CLK_REG              |
| SCAN_CLK         | I | 1  | CLK in scan mode                                                              | Up to 10MHz            |
| SCAN_MODE        | I | 1  | SCAN_MODE                                                                     | Level(CLK_REG domain)  |
| SCAN_RSTB        | I | 1  | Async resetb in scan mode                                                     | Level(CLK_32M domain)  |
| Scan_enable      | I | 1  | 1:shift mode 0:capture mode or function mode                                  | 4 CLK_32M              |

## **Clock Domain**

The clock for COMM\_REG is CLK\_REG\_SC and CLK\_8M\_256K\_SC. For u\_FLT\_BIT and u\_FLT\_SUM, both CLK\_REG\_SC and CLK\_8M\_256K\_SC are used. For other sub-modules, only CLK\_REG\_SC is used.

## **COMM\_REG** function description

#### 1 Control bits

TO\_SD bit is defined in reg2002[1]. TO\_SD is synchronized in module u\_TO\_SD\_sync by CLK\_SLOW, and module u\_TO\_SD\_sync output D2A\_TO\_SD for analog. Analog shutdown digital part, thus TO SD and D2A TO SD are both pulses.(HWR001 COMM REG)

TO\_SLEEP bit is defined in reg2002[0]. TO\_SLEEP is synchronized in module u\_TO\_SLEEP\_sync by CLK\_SLOW, and module u\_TO\_SLEEP\_sync output D2A\_TO\_SLEEP for analog, and then generate clr\_TO\_SLEEP for u\_COMM\_REG to clear TO\_SLEEP, thus TO\_SLEEP is a pulse.(HWR002\_COMM\_REG)

PROG\_SCTO[2:0] is defined in reg0004[2:0]. (HWR003\_COMM\_REG)

PROG LCTO[2:0] is defined in reg0004[5:3]. (HWR004 COMM REG)

LCTO SEL[1:0] is defined in reg0004[7:6]. (HWR005 COMM REG)

ADC\_SGLE\_GO is defined in reg2004[1], ADC\_CNTI\_GO is defined in reg2004[0]. Both ADC\_SGLE\_GO and ADC\_CNTI\_GO are cleared by clr\_ADC\_GO. (HWR011\_COMM\_REG)

MON\_WAKE\_GO is defined in reg2004[7]. MON\_WAKE\_GO is cleared by clr MON WAKE GO. (HWR012 COMM REG)

MON EN REG is defined in reg000D[0]. (HWR050 COMM REG)

FREEZE is defined in reg2004[2]. (HWR013\_COMM\_REG)

DLPF FC[2:0] is defined in reg0008[7:5]. (HWR015 COMM REG)

STACK RESPONSE[5:0] is defined in reg0003[5:0]. (HWR019 COMM REG)

COMN\_TX\_DIS is defined in reg0003[7], COMN\_TX\_DIS is defined in reg0003[6]. (HWR054 COMM REG)

SD\_TONE\_GEN is defined in reg2002[2], use SPI\_DIR as SD\_TONE\_DIR. SPI\_DIR is defined in reg2003[0]. (HWR051\_COMM\_REG) SD\_TONE\_GEN is cleared by clr SD\_TONE\_GEN. (HWR020\_COMM\_REG)

WAKE\_TONE\_GEN is defined in reg2002[4], WAKE\_TONE\_GEN reset to 0 when clr WAKE TONE GEN is high. (HWR052 COMM REG)

STA\_TONE\_GEN is defined in reg2002[3], STA\_TONE\_GEN reset to 0 when clr STA TONE GEN is high. (HWR053 COMM REG)

All fault bits have corresponding mask bits. Mask bits are defined in reg0100~0117. (HWR036\_COMM\_REG)

MTP\_CTRL\_BITS are defined in reg1FFB~1FFF. They are writable only when TRIM\_EN high. (HWR043 COMM REG)

I2C\_CTRL bits include i2c\_stop, i2c\_rx, i2c\_sr, i2c\_tx. These 4 bits are defined in reg2200. I2C\_MAS\_EN is defined in reg0002[0]. I2C\_CTRL include i2c\_tx\_data[7:0], which is defined in reg2201. I2c\_rd\_data[7:0] is readable from address 0x2202. I2c\_ack\_out is readable from bit 4 of address 2200. (HWR047 COMM REG)

SOFT\_RSTB\_REG is defined in reg2002[7]. SOFT\_RSTB\_REG is default high. When written 0 via COMM\_CTRL, SOFT\_RSTB\_REG is low. SOFT\_RSTB\_REG reset to high when clr SOFT\_RSTB\_high. (HWR049\_COMM\_REG)

#### 2 Trim bits

```
TRIM_ADC bits are defined in reg1000~reg105F. (HWR008_COMM_REG)
TRIM_ANA bits are defined in reg1060~reg107A. (HWR042_COMM_REG)
```

X-Y and lot information are readable from address 0x107C~107D. These bits are writable only when TRIM EN high. (HWR048 COMM REG)

## 3 Setting bits

```
ADC_SETTING_REG bits are defined in reg0008~reg000C. (HWR010_COMM_REG)

MON_WAKE_PERIOD_REG[5:0] is defined in reg000D[7:2]. (HWR031_COMM_REG)

CELL_OV_THRESH_REG[6:0] is defined in reg000F[6:0],

CELL_UV_THRESH_REG[6:0] is defined in reg0010[6:0]. (HWR041_COMM_REG)

GPIO_OT_PACK_THRESH_REG[4:0] is defined in reg0011[7:3],

GPIO_UT_PACK_THRESH_REG[2:0] is defined in reg0011[2:0],

GPIO_OT_PCB_THRESH_REG[4:0] is defined in reg0012[7:3],

GPIO_UT_PCB_THRESH_REG[2:0] is defined in reg0012[2:0]. (HWR044_COMM_REG)

GPIO_PUPD[11:0] is defined in reg202D~202E, GPIO_PUPD_EN[11:0] is defined in reg0019~001A, GPIO_AS_IN_EN[11:0] is defined in reg001B~001C. (HWR045_COMM_REG)

GPIO_HL[11:0] is readable from address 0x5002~5003. (HWR046_COMM_REG)

OVUV_DEGL_REG[4:0] is defined in reg000E[4:0]. (HWR056_COMM_REG)

OVUV_OTUT_EN_REG is defined in reg000E[7]. (HWR057_COMM_REG)
```

#### 4 ADC results

ADC DATA LPF are readable from address 0x4000~0x4023. (HWR009 COMM REG)

CELL\_ADC\_DATA are readable from address 0x4048~0x406B, OTH\_ADC\_DATA are readable from address 0x4090~0x40A7, 0x40C0~0x40C5. (HWR014 COMM REG)

RR\_COUNTER is readable from address 0x3FFE~0x3FFF. (HWR016\_COMM\_REG, HWR018\_COMM\_REG)

#### 5 COMM\_DIG\_SETTING

TOP\_DEV is defined in reg0000[7], DIR\_SEL is defined in reg2002[6], DEV\_ADD[6:0] is defined in reg0000[6:0], DEV\_NUM[6:0] is defined in reg0001[6:0]. (HWR021 COMM REG, HWR024 COMM REG)

Default values of COMM\_DIG\_SETTING registers are from XXX\_LATCH. DEV\_ADD cannot be changed when ADD\_W\_EN is low. (HWR023\_COMM\_REG)

ADD\_W\_EN is defined in reg2003[1]. ADD\_W\_EN is high when address identify starts. ADD\_W\_EN is cleared by writing reg2003[1] to 0.(HWR021\_COMM\_REG, HWR022\_COMM\_REG)

DEV\_NUM[6:0] indicates the device number from current device to the top device. DEV\_NUM[6:0] adds by step 1 when receiving device response when ADD\_W\_EN high(in address identify response stage). DEV\_NUM[6:0] reset to 0 when address identify starts. (HWR024\_COMM\_REG)

#### 6 CB CTRL SETTING REG

CBFET\_EN\_REG1~18 are defined in reg2006~2008. CB\_GO is defined in reg2005[0]. CB\_GO is high when written high, is low when clr\_CB\_GO high. CB\_MANUAL\_REG is defined in reg2005[2]. (HWR025\_COMM\_REG)

CB\_TO\_THRESH\_REG1~18[9:0] and CB\_UNIT\_REG[17:0] are defined in reg2009~202C. (HWR026 COMM REG)

CB TWARN THRESH REG[3:0] is defined in reg0017[7:4]. (HWR027 COMM REG)

JOT EN REG is defined in reg0017[1]. (HWR028 COMM REG)

GPIO CBOT EN REG is defined in reg0017[3]. (HWR029 COMM REG)

CB\_OT\_PACK\_THRSH\_REG[4:0] is defined in reg0015[7:3], CB\_OT\_PCB\_THRSH\_REG[4:0] is defined in reg0016[7:3]. GPIO\_OTUT\_THRESH\_SEL\_REG[11:0] is defined in reg0013~0014. (HWR030\_COMM\_REG)

CB\_MANU\_PAUSE is defined in reg2005[1]. (HWR033\_COMM\_REG)

ADC PAUSE EN REG is defined in reg0017[2]. (HWR034 COMM REG)

```
FLT STOP EN REG is defined in reg0017[0]. (HWR035 COMM REG)
```

CB PERIOD REG[2:0] is defined in reg0016[2:0]. (HWR037 COMM REG)

CB DUTY REG[2:0] is defined in reg0015[2:0]. (HWR038 COMM REG)

CB\_ODD\_CNT[15:0] and CB\_EVEN\_CNT[15:0] are readable from address 0x5007~500A. (HWR039\_COMM\_REG)

CB CH EN FULL DUTY[17:0] are readable from address 0x5004~5006. (HWR040 COMM REG)

CB SETTLE[4:0] is defined in reg0002[7:3]. (HWR055 COMM REG)

### 7 Fault regs

Fault regs include FLT\_BIT registers and FLT\_SUM registers. FLT\_BIT registers are located in addresses 0x5101~5117, FLT SUM registers are located in address 0x5100.

SCTO flag bit is defined in reg5116[6], it is set by SET SCTO. (HWR001 FLT REG)

LCTO flag bit is defined in reg5116[5], when it is set by SET\_LCTO or by LCTO\_LATCH. (HWR002 FLT REG)

LCTO\_SD, VAA\_OKB, VDD\_OKB, CLK\_256K\_OKB, VDD\_OV, VDD\_UV flag bits are defined in address 0x5115. They support being only set by corresponding input XXX\_LATCH. FLT\_BIT output RST XXX LATCH when register bits is written to 1. (HWR003 FLT REG)

FLT\_TONE\_DET\_REG is recorded in reg5117[0]. FLT\_TONE\_DET\_REG shall be high when FLT TONE DET is high. (HWR004 FLT REG)

GPIO\_OTUT (including GPIO\_OT[11:0] and GPIO\_UT[11:0]) are recorded in FLT\_REG. OT\_FLT[11:0] recording GPIO\_OT faults, are in address 0x510F~5110, UT\_FLT[11:0] recording GPIO\_UT fault, are in address 0x5111~5112. (HWR005 FLT REG)

CELL\_OVUV (including CELL\_OV[17:0] and CELL\_UV[17:0]) are recorded in FLT\_REG. OV\_FLT[17:0] recording CELL\_OV faults, are in address 0x5104~5106, UV\_FLT[17:0] recording CELL UV faults, are in address 0x5107~5109. (HWR006 FLT REG)

Every fault bit has its corresponding mask bit. All fault bits can not be set high when corresponding mask bit(from reg0100~0117) is 1. (HWR009 FLT REG)

```
COW[18:0] are fault flag from u C OW CTRL, are in address 0x5101~5103. (HWR010 FLT REG)
```

All fault bits can not be written to 1 via COMM\_CTRL. When corresponding mask bit is 0, all fault bits can be cleared to 0 when written 0 via COMM\_CTRL. (HWR011\_FLT\_REG)

```
CB CONF FLT is recorded in reg5116[7]. (HWR012 FLT REG)
```

RX\_FIFO\_OF\_REG bit set by RX\_FIFO\_OF is recorded in reg5116[3], TX\_FIFO\_OF\_REG bit set by TX FIFO OF is recorded in reg5116[2]. (HWR013 FLT REG)

TX FIFO UF REG bit set by TX FIFO UF is recorded in reg5116[1]. (HWR014 FLT REG)